## RISC-V cheatsheet



By: Carl van Heezik



All RISC-V processors must implement the base integer instruction set known under the acronym RV32I. The encoding of RISC-V base integer instructions is 32 bits wide. A RISC-V processor has 32 general purpose x-registers and a program counter register. This cheatsheet shows an overview of the assembly instructions.

# RISC-V registers



| register   | ABI  | description          | register | ABI | description          |
|------------|------|----------------------|----------|-----|----------------------|
| xO         | zero | always zero          | x16      | a6  | function argument 6  |
| x1         | ra   | call return address  | x17      | a7  | function argument 7  |
| x2         | sp   | stack pointer        | x18      | s2  | saved register 2     |
| <b>x</b> 3 | gp   | global pointer       | x19      | s3  | saved register 3     |
| x4         | tp   | thread pointer       | x20      | s4  | saved register 4     |
| x5         | t0   | temporary register o | x21      | s5  | saved register 5     |
| x6         | t1   | temporary register 1 | x22      | s6  | saved register 6     |
| x7         | t2   | temporary register 2 | x23      | s7  | saved register 7     |
| 8x         | s0   | saved register o     | x24      | s8  | saved register 8     |
| x9         | s1   | saved register 1     | x25      | s9  | saved register 9     |
| x10        | a0   | function argument o  | x26      | s10 | saved register 10    |
| x11        | a1   | function argument 1  | x27      | s11 | saved register 11    |
| x12        | a2   | function argument 2  | x28      | t3  | temporary register 3 |
| x13        | a3   | function argument 3  | x29      | t4  | temporary register 4 |
| x14        | a4   | function argument 4  | x30      | t5  | temporary register 5 |
| x15        | a5   | function argument 5  | x31      | t6  | temporary register 6 |

## **RV32I instructions**

#### Acronyms

• xD : Destination register x0...x31

• x5 : Source register x0...x31

• xL: Left register x0...x31

• xR : Right register x0...x31

• xB : Base register x0...x31

### Register-register instructions

| mnemonic | destination<br>register | source 1<br>register | source 2<br>register | description            |
|----------|-------------------------|----------------------|----------------------|------------------------|
| ADD      | xD,                     | xL,                  | xR                   | Add                    |
| SUB      | xD,                     | xL,                  | xR                   | Subtract               |
| AND      | xD,                     | xL,                  | xR                   | AND                    |
| OR       | xD,                     | xL,                  | xR                   | OR                     |
| XOR      | xD,                     | xL,                  | xR                   | XOR                    |
| SLT      | xD,                     | xL,                  | xR                   | Set Less Than          |
| SLTU     | xD,                     | xL,                  | xR                   | Set Less Than Unsigned |
| SLL      | xD,                     | xL,                  | xR                   | Shift Left Logical     |
| SRL      | xD,                     | xL,                  | xR                   | Shift Right Logical    |
| SRA      | xD,                     | xL,                  | xR                   | Shift Right Arithmetic |

#### Immediate instructions

| mnemonic | destination<br>register | source 1<br>register | immediate | description                      |
|----------|-------------------------|----------------------|-----------|----------------------------------|
| ADDI     | xD,                     | xL,                  | CONSTANT  | Add Immediate                    |
| ANDI     | xD,                     | xL,                  | CONSTANT  | AND Immediate                    |
| ORI      | xD,                     | xL,                  | CONSTANT  | OR Immediate                     |
| XORI     | xD,                     | xL,                  | CONSTANT  | XOR Immediate                    |
| SLTI     | xD,                     | xL,                  | CONSTANT  | Set Less Than Immediate          |
| SLLI     | xD,                     | xL,                  | SHIFT     | Shift Left Logical Immediate     |
| SRLI     | xD,                     | xL,                  | SHIFT     | Shift Right Logical Immediate    |
| SRAI     | xD,                     | xL,                  | SHIFT     | Shift Right Arithmetic Immediate |

#### **Conditional branches**

| mnemonic | source 1<br>register | source 2<br>register | immediate | description                   |
|----------|----------------------|----------------------|-----------|-------------------------------|
| BEQ      | xL,                  | xR,                  | OFFSET    | Branch Equal                  |
| BNE      | xL,                  | xR,                  | OFFSET    | Branch Not Equal              |
| BLT      | xL,                  | xR,                  | OFFSET    | Branch Less Than              |
| BGE      | xL,                  | xR,                  | OFFSET    | Branch Greater Equal          |
| BLTU     | xL,                  | xR,                  | OFFSET    | Branch Less Than Unsigned     |
| BGEU     | xL,                  | xR,                  | OFFSET    | Branch Greater Equal Unsigned |

### Upper immediate instructions

| mnemonic | destination<br>register | immediate | description               |  |  |  |
|----------|-------------------------|-----------|---------------------------|--|--|--|
| LUI      | xD,                     | UPPER     | Load Upper Immediate      |  |  |  |
| AUIPC    | xD,                     | UPPER     | Add upper Immediate to PC |  |  |  |

### **Unconditional jumps**

| mnemonic | destination<br>register | immediate | description   |
|----------|-------------------------|-----------|---------------|
| JAL      | xD,                     | OFFSET    | Jump AND Link |

## Indirect jump instruction

| mnemonic | destination<br>register | source 1<br>register | immediate | description            |
|----------|-------------------------|----------------------|-----------|------------------------|
| JALR     | xD,                     | xL,                  | OFFSET    | Jump and Link Register |

#### Load and store instruction

| mnemonic | destination | immediate | source 1 | description        |
|----------|-------------|-----------|----------|--------------------|
|          | register    |           | register |                    |
| LB       | xD,         | OFFSET    | (xB)     | Load Byte          |
| LH       | xD,         | OFFSET    | (xB)     | Load Half          |
| LW       | xD,         | OFFSET    | (xB)     | Load word          |
| LBU      | xD,         | OFFSET    | (xB)     | Load Byte Unsigned |
| LHU      | xD,         | OFFSET    | (xB)     | Load Half Unsigned |

| mnemonic | source 2 | immediate | source 1 | description         |
|----------|----------|-----------|----------|---------------------|
|          | register |           | register |                     |
| SB       | xS,      | OFFSET    | (xB)     | Store Byte          |
| SH       | xS,      | OFFSET    | (xB)     | Store Half          |
| SW       | xS,      | OFFSET    | (xB)     | Store word          |
| SBU      | xS,      | OFFSET    | (xB)     | Store Byte Unsigned |
| SHU      | xS,      | OFFSET    | (xB)     | Store Half Unsigned |

## Memory ordering instructions

| mnemonic | predecessor | successor | description       |
|----------|-------------|-----------|-------------------|
| FENCE    | IORW,       | IORW      | Fence             |
| FENCE.I  |             |           | Fence instruction |

# RV32I encoding

| [31:25]<br>7 | [24:20]<br>5 | [19:15]<br>5 | [14:12]<br>3 | [11:7]<br>5 | [6:0]<br>7  |
|--------------|--------------|--------------|--------------|-------------|-------------|
| function 7   | source 2     | source 1     | function 3   | destination | opcode      |
| 0000000      | xR           | xL           | 000 : ADD    | xD          | 0110011: OP |
| 0100000      | xR           | xL           | 000 : SUB    | xD          | 0110011: OP |
| 0000000      | xR           | xL           | 001 : SLL    | xD          | 0110011: OP |
| 0000000      | xR           | xL           | 010 : SLT    | xD          | 0110011: OP |
| 0000000      | xR           | xL           | 011 : SLTU   | xD          | 0110011: OP |
| 0000000      | xR           | xL           | 100 : XOR    | xD          | 0110011: OP |
| 0000000      | xR           | xL           | 101 : SRL    | xD          | 0110011: OP |
| 0100000      | xR           | xL           | 101 : SRA    | xD          | 0110011: OP |
| 0000000      | xR           | xL           | 110 : OR     | xD          | 0110011: OP |
| 0000000      | xR           | xL           | 111 : AND    | xD          | 0110011: OP |

| [31:20]<br>12   | [19:15]<br>5 | [14:12]<br>3 | [11:7]<br>5 | [6:0]<br>7       |
|-----------------|--------------|--------------|-------------|------------------|
| IMMEDIATE[11:0] | source 1     | function 3   | destination | opcode           |
| CONSTANT[11:0]  | xL           | 000 : ADDI   | xD          | 0010011 : OP-IMM |
| CONSTANT[11:0]  | xL           | 010 : SLTI   | xD          | 0010011 : OP-IMM |
| CONSTANT[11:0]  | xL           | 011 : SLTIU  | xD          | 0010011 : OP-IMM |
| CONSTANT[11:0]  | xL           | 100 : XORI   | xD          | 0010011 : OP-IMM |
| CONSTANT[11:0]  | xL           | 110 : ORI    | xD          | 0010011 : OP-IMM |
| CONSTANT[11:0]  | xL           | 111 : ANDI   | xD          | 0010011 : OP-IMM |

| [31:25]         | [24:20]        | [19:15]  | [14:12]    | [11:7]      | [6:0]            |  |  |
|-----------------|----------------|----------|------------|-------------|------------------|--|--|
| 7               | 5              | 5        | 3          | 5           | 7                |  |  |
| IMMEDIATE[11:5] | IMMEDIATE[4:0] | source 1 | function 3 | destination | opcode           |  |  |
| 0000000         | SHIFT          | xL       | 001 : SLLI | xD          | 0010011 : OP-IMM |  |  |
| 0000000         | SHIFT          | xL       | 101 : SRLI | xD          | 0010011 : OP-IMM |  |  |
| 0100000         | OOO SHIFT      |          | 101 : SRAI | xD          | 0010011 : OP-IMM |  |  |

| [31]  | [30:25] | [24:20]  | [19:15]  | [14:12]    | [11:8] | [7]   | [6:0]            |
|-------|---------|----------|----------|------------|--------|-------|------------------|
| 1     | 6       | 5        | 5        | 3          | 4      | 1     | 7                |
| I[12] | I[10:5] | source 2 | source 1 | function 3 | I[4:1] | I[11] | opcode           |
| 0[12] | 0[10:5] | xR       | xL       | 000 : BEΩ  | 0[4:1] | 0[11] | 1100011 : BRANCH |
| 0[12] | 0[10:5] | xR       | xL       | 001 : BNE  | 0[4:1] | 0[11] | 1100011 : BRANCH |
| 0[12] | 0[10:5] | xR       | xL       | 100 : BLT  | 0[4:1] | 0[11] | 1100011 : BRANCH |
| 0[12] | 0[10:5] | xR       | xL       | 101 : BGE  | 0[4:1] | 0[11] | 1100011 : BRANCH |
| 0[12] | 0[10:5] | xR       | xL       | 110 : BLTU | 0[4:1] | 0[11] | 1100011 : BRANCH |
| 0[12] | O[10:5] | xR       | xL       | 111 : BGEU | 0[4:1] | 0[11] | 1100011 : BRANCH |

| [31:12]<br>20    | [11:7]<br>5 | [6:0]<br>7      |  |
|------------------|-------------|-----------------|--|
| IMMEDIATE[31:12] | destination | opcode          |  |
| UPPER[31:12]     | xD          | 0110111 : LUI   |  |
| UPPER[31:12]     | xD          | 0010111 : AUIPC |  |

| [31]  | [30:21] | [20]  | [19:12]          | [11:7]      | [6:0]        |
|-------|---------|-------|------------------|-------------|--------------|
| 1     | 10      | 1     | 8                | 5           | 7            |
| I[20] | I[10:1] | I[11] | IMMEDIATE[19:12] | destination | opcode       |
| 0[20] | 0[10:1] | 0[11] | 0[19:12]         | xD          | 1101111: JAL |

| [31:20]         | [19:15]  | [14:12]    | [11:7]      | [6:0]          |
|-----------------|----------|------------|-------------|----------------|
| 12              | 5        | 3          | 5           | 7              |
| IMMEDIATE[11:0] | source 1 | function 3 | destination | opcode         |
| OFFSET[11:0]    | xL       | 0          | xD          | 1100111 : JALR |

| [31:20]<br>12   | [19:15]<br>5 | [14:12]<br>3 | [11:7]<br>5 | [6:0]<br>7     |
|-----------------|--------------|--------------|-------------|----------------|
| IMMEDIATE[11:0] | source 1     | function 3   | destination | opcode         |
| OFFSET[11:0]    | хВ           | 000 : LB     | xD          | 0000011 : LOAD |
| OFFSET[11:0]    | хВ           | 001 : LH     | xD          | 0000011 : LOAD |
| OFFSET[11:0]    | хВ           | 010 : LW     | xD          | 0000011 : LOAD |
| OFFSET[11:0]    | хВ           | 100 : LBU    | xD          | 0000011 : LOAD |
| OFFSET[11:0]    | хB           | 101 : LHU    | хD          | 0000011 : LOAD |

| [31:25]<br>7    | [24:20]<br>5 | [19:15]<br>5 | [14:12]<br>3 | [11:7]<br>5    | [6:0]<br>7      |
|-----------------|--------------|--------------|--------------|----------------|-----------------|
| IMMEDIATE[11:5] | source 2     | source 1     | function 3   | IMMEDIATE[4:0] | opcode          |
| OFFSET[11:5]    | xS xB        |              | 000 : SB     | OFFSET         | 0100011 : STORE |
| OFFSET[11:5]    | xS           | хВ           | 001 : SH     | OFFSET         | 0100011 : STORE |
| OFFSET[11:5]    | xS           | хВ           | 010 : SW     | OFFSET         | 0100011 : STORE |
| OFFSET[11:5]    | xS           | хВ           | 100 : SBU    | OFFSET         | 0100011 : STORE |
| OFFSET[11:5]    | xS           | хВ           | 101 : SHU    | OFFSET         | 0100011 : STORE |

| [31:28 | 8] | [27] | [26] | [25] | [24] | [23] | [22] | [21] | [20] | [19:15]  | [14:12]      | [11:7]      | [6:0]              |
|--------|----|------|------|------|------|------|------|------|------|----------|--------------|-------------|--------------------|
| 4      |    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 5        | 3            | 5           | 7                  |
| FM     |    | PI   | РО   | PR   | PW   | SI   | 50   | SR   | SW   | source 1 | function 3   | destination | opcode             |
| 0000   |    | PI   | РО   | PR   | PW   | SI   | 50   | SR   | SW   | 00000    | 000: FENCE   | 00000       | 0001111 : MISC-MEM |
| 0000   |    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 00000    | 001: FENCE.I | 00000       | 0001111 : MISC-MEM |

← KENDRYTE K210 DEBUGGING